layui.define(['table', 'jquery', 'element'], function (exports) {
    "use strict";

    var MOD_NAME = 'pearMenu',
        $ = layui.jquery,
		element = layui.element;
		
    var pearMenu = function (opt) {
        this.option = opt;
    };

    pearMenu.prototype.render = function (opt) {
        //默认配置值
		var option = {
			elem:opt.elem,
			async:opt.async ? opt.async : false,
			parseData:opt.parseData,
			url:opt.url,
			defaultOpen:opt.defaultOpen,
			control:opt.control,
			defaultMenu:opt.defaultMenu,
			accordion:opt.accordion,
			height:opt.height,
			theme:opt.theme,
			data:opt.data ? opt.data:[],
			done:opt.done ? opt.done: function(){ console.log("菜单渲染成功");}
		}
		
		
		// 根 据 请 求 方 式 获 取 数 据
		if(option.async){
			option.data =  getData(option.url);
		    if(option.parseData!=false){
		        option.parseData(option.data);
		    }
		}
		
		if(option.control!=false){
			
			createMenuAndControl(option);
			
		}else{
			createMenu(option);
		}
	
		
	    // 渲 染 菜 单 结 束 并 完 成
		element.init();
		
		downShow(option);
		
		
		
		option.done();
		return new pearMenu(option);
    } 

	
	/** 监听事件赋值 */
	pearMenu.prototype.click = function(clickEvent){
		
		var _this = this;
		$("#"+_this.option.elem+" .site-demo-active").parent().click(function(){
			var dom = $(this).children(".site-demo-active");
			var data  = {menuId:dom.attr("menu-id"),menuTitle:dom.attr("menu-title"),menuIcon:dom.attr("menu-icon"),menuUrl:dom.attr("menu-url")};	
		    clickEvent(dom,data);
		});
		
	}
	
	
	pearMenu.prototype.skin = function(skin){
		
		var menu = $(".pear-nav-tree[lay-filter='"+this.option.elem+"']").parent();
	
	    menu.removeClass("dark-theme");
		menu.removeClass("light-theme");
		
		menu.addClass(skin);
	}
	
	
	pearMenu.prototype.selectItem = function(pearId){
		
		if(this.option.control != false){
			
			$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".layui-side-scroll ").find("ul").css({display:"none"});
			
			$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".layui-side-scroll ").find(".layui-this").removeClass("layui-this");
			
			$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents("ul").css({display:"block"});
			
			var controlId = $("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents("ul").attr("pear-id");
			
			$("#"+this.option.control).find(".layui-this").removeClass("layui-this");
			
			$("#"+this.option.control).find("[pear-id='"+controlId+"']").addClass("layui-this");
		}
		
		
		// 根 据 菜 单 Id 选 中 菜 单 项 目
		
		
		$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".pear-nav-tree").find(".layui-nav-itemed").removeClass("layui-nav-itemed");
		
		$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".pear-nav-tree").find(".layui-this").removeClass("layui-this");
		
		// 通 过 动 画 打 开 当 前 菜 单 项 layui-nav-child
		
		if(!$("#"+this.option.elem).is(".pear-nav-mini")){
		
		      $("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents(".layui-nav-item").addClass("layui-nav-itemed");
			  
		      $("#"+this.option.elem+" a[menu-id='"+pearId+"']").parents("dd").addClass("layui-nav-itemed");
		
		}
		
		$("#"+this.option.elem+" a[menu-id='"+pearId+"']").parent().addClass("layui-this");
		
		
	}
	
	
	var activeMenus;
	
	pearMenu.prototype.collaspe = function(time){
		
		var elem = this.option.elem;
		
		var config = this.option;
		
		if($("#"+this.option.elem).is(".pear-nav-mini")){
		    
			$.each(activeMenus,function(i,item){
				$("#"+elem+" a[menu-id='" + $(this).attr("menu-id") + "']").parent().addClass("layui-nav-itemed");
			})
		  
		    $("#"+this.option.elem).removeClass("pear-nav-mini");
		
		    $("#"+this.option.elem).animate({
					width: "220px"
				},150);
		
		    isHoverMenu(false,config);
			
		}else{
			
			activeMenus = $("#"+this.option.elem).find(".layui-nav-itemed>a");
			$("#"+this.option.elem).find(".layui-nav-itemed").removeClass("layui-nav-itemed");
			
			$("#"+this.option.elem).addClass("pear-nav-mini");
		  
		    $("#"+this.option.elem).animate({
					width: "60px"
				},400);
			isHoverMenu(true,config);
		
		}
	}
	
    /** 同 步 请 求 获 取 数 据 */
    function getData(url){
		
		$.ajaxSettings.async = false;
		var data = null;
		
		$.get(url, function(result) {
			data = result;
		});
		
		$.ajaxSettings.async = true;
		return data;
	}
	
	
	function createMenu(option){
	    // 声 明 头 部
		var menuHtml = '<ul lay-filter="'+option.elem+'" class="layui-nav arrow   pear-menu layui-nav-tree pear-nav-tree">'
		// 开 启 同 步 操 作
		    $.each(option.data, function(i, item) {
		        // 创 建 每 一 个 菜 单 项
				
				
				var content = '<li class="layui-nav-item" >';
				
				if(i==option.defaultOpen && option.defaultOpen!=false){
					content = '<li class="layui-nav-item layui-nav-itemed" >';
				}
				
				var href = "javascript:;";
				var target = "";
				var calss = "site-demo-active"
				
				if(item.openType == "_blank" && item.type == 1){
					href = item.href;
					target = "target='_blank'";
					calss = "";
				}
				
				// 判 断 菜 单 类 型 0 是 不可跳转的目录 1 是 可 点 击 跳 转 的 菜 单
				if (item.type == 0) {
					// 创 建 目 录 结 构
					content += '<a  href="javascript:;" menu-type="'+item.type+'" menu-id="'+item.id+'" href="'+ href +'" '+ target +'><i class="' + item.icon + '"></i><span>' + item.title +
						'</span></a>';
				} else if (item.type == 1) {
					// 创 建 菜 单 结 构
					content += '<a class="'+calss+'" menu-type="'+item.type+'" menu-url="' + item.href + '" menu-id="' + item.id +
						'" menu-title="' + item.title + '"  href="'+href+'"  '+ target +'><i class="' + item.icon +
						'"></i><span>' + item.title + '</span></a>';
				}
				// 调 用 递 归 方 法 加 载 无 限 层 级 的 子 菜 单 
				content += loadchild(item);
				// 结 束 一 个 根 菜 单 项
				content += '</li>';
				menuHtml += content;
		
			});
			// 结 束 菜 单 结 构 的 初 始 化
			menuHtml += "</ul>";
		    // 将 菜 单 拼 接 到 初 始 化 容 器 中

	    $("#"+option.elem).html(menuHtml);
		
	}
	
	
	function createMenuAndControl(option){
	
	    var control = '<ul class="layui-nav pear-nav-control">';
		// 声 明 头 部
		var menu = '<div class="layui-side-scroll '+option.theme+'">'
		// 开 启 同 步 操 作
		
		var index = 0;
		   
		$.each(option.data, function(i, item) {
			
			var menuItem = '';
			
			var controlItem = '';
			
			
			if(index === option.defaultMenu){
	              
				controlItem  = '<li pear-id="'+item.id+'" class="layui-this layui-nav-item"><a href="#">'+item.title+'</a></li>';
				  			
				menuItem = '<ul  pear-id="'+item.id+'" lay-filter="'+option.elem+'" class="layui-nav arrow layui-nav-tree pear-nav-tree">';
				   
			}else{
				
				
				controlItem = '<li pear-id="'+item.id+'" class="layui-nav-item"><a href="#">'+item.title+'</a></li>';
							
				menuItem = '<ul style="display:none" pear-id="'+item.id+'" lay-filter="'+option.elem+'" class="layui-nav arrow layui-nav-tree pear-nav-tree">';
				
			}
			
			index ++;
			
			$.each(item.children,function(i,note){
				
				// 创 建 每 一 个 菜 单 项
				var content = '<li class="layui-nav-item" >';
				
				var href = "javascript:;";
				
				var target = "";
				
				var calss = "site-demo-active";
				
				if(note.openType == "_blank" && note.type == 1){
					
					href = note.href;
					target = "target='_blank'";
					calss = "";
				}
				
			
			    // 判 断 菜 单 类 型 0 是 不可跳转的目录 1 是 可 点 击 跳 转 的 菜 单
				if (note.type == 0) {
					// 创 建 目 录 结 构
					content += '<a  href="'+href+'" '+ target +' menu-type="'+note.type+'" menu-id="'+note.id+'" ><i class="' + note.icon + '"></i><span>' + note.title +
						'</span></a>';
				} else if (note.type == 1) {
					// 创 建 菜 单 结 构
					content += '<a '+ target +' class="'+calss+'" menu-type="'+note.type+'" menu-url="' + note.href + '" menu-id="' + note.id +
						'" menu-title="' + note.title + '" href="'+href+'"><i class="' + note.icon +
						'"></i><span>' + note.title + '</span></a>';
				}
				// 调 用 递 归 方 法 加 载 无 限 层 级 的 子 菜 单 
				content += loadchild(note);
				// 结 束 一 个 根 菜 单 项
				content += '</li>';
				
				menuItem += content;
				
			})
			
			
			menu += menuItem + '</ul>';
			
			control += controlItem;
			
		})	
		
		
		$("#"+option.control).html(control);
		
		$("#"+option.elem).html(menu);
		
		$("#"+option.control+" .pear-nav-control").on("click","li",function(){
			
			$("#"+option.elem).find(".pear-nav-tree").css({display:'none'});
			
			$("#"+option.elem).find(".pear-nav-tree[pear-id='"+$(this).attr("pear-id")+"']").css({display:'block'});
			
		})
			
		
			
	
		
	}
	
    /** 加载子菜单 (递归)*/
	function loadchild(obj) {
		
		// 判 单 是 否 是 菜 单， 如 果 是 菜 单 直 接 返 回
		if(obj.type==1){
			return "";
		}
		
		// 创 建 子 菜 单 结 构
		var content = '<dl class="layui-nav-child">';
		
		// 如 果 嵌 套 不 等 于 空 
		if (obj.children != null && obj.children.length > 0) {
			// 遍 历 子 项 目
			$.each(obj.children, function(i, note) {
				// 创 建 子 项 结 构
				content += '<dd>';
				
				var href = "javascript:;";
				
				var target = "";
				
				var calss = "site-demo-active";
				
				if(note.openType == "_blank" && note.type == 1){
					href = note.href;
					target = "target='_blank'";
					calss = "";
				}
				
	            // 判 断 子 项 类 型
				if (note.type == 0) {
					// 创 建 目 录 结 构
	                content += '<a '+ target +'  href="'+href+'" menu-type="'+note.type+'" menu-id="'+note.id+'"><i class="' + note.icon + '"></i><span>' + note.title + '</span></a>';
				} else if (note.type == 1) {
					// 创 建 菜 单 结 构
					content += '<a '+ target +' class="'+calss+'" menu-type="'+note.type+'" menu-url="' + note.href + '" menu-id="' + note.id +'" menu-title="' + note.title + '" menu-icon="' + note.icon + '" href="'+href+'" ><i class="' + note.icon +'"></i><span>' + note.title + '</span></a>';
				}
				// 加 载 子 项 目 录
				content += loadchild(note);
				// 结 束 当 前 子 菜 单
				content += '</dd>';
			});
	        // 封 装
			
		}else{
			content += '<div class="toast"> 无 内 容 </div>';
		
		   /* 暂 无 数 据&nbsp;&nbsp;&nbsp;&nbsp; */
		}
		
		content += '</dl>';
		return content;
	}
	
	
	
	function downShow(option){
		
		 $("body #"+option.elem).on("click","a[menu-type='0']",function(){
			
			if(!$("#"+option.elem).is(".pear-nav-mini")){
				
			var superEle = $(this).parent();
			var ele = $(this).next('.layui-nav-child');
			var height = ele.height();
			if($(this).parent().is(".layui-nav-itemed")){
				
				
				if(option.accordion){
				// 手 风 琴 实 现
				$(this).parent().parent().find(".layui-nav-itemed").removeClass("layui-nav-itemed");
				$(this).parent().addClass("layui-nav-itemed");			
				
				}
				
				ele.height(0);
				
				ele.animate({
					height: height + "px"
				},200,function() {
					ele.css({
						height: "auto"
					});
				}); 
			
			}else{
			 	
				$(this).parent().addClass("layui-nav-itemed");
				
				ele.animate({
					height: "0px"
				},200,function() {
					ele.css({
						height: "auto"
					});
					$(this).parent().removeClass("layui-nav-itemed");
				}); 
						
			}
			}
		})
		 
		
	}
	
	/** 二 级 悬 浮 菜 单*/
	function isHoverMenu(b,option) {
			if (b) {
				$("#"+option.elem+".pear-nav-mini .layui-nav-item,#"+option.elem+".pear-nav-mini dd").hover(function() {
					
					$(this).children(".layui-nav-child").addClass("layui-nav-hover");
					
					var top = $(this).offset().top+5;
					
					
					if (!$(this).is(".layui-nav-item")) {
					    
						var left = $(this).offset().left + 132;
						
						$(this).children(".layui-nav-child").offset({left:left});
				
					}else{
						var left = $(this).offset().left + 62 ;
						
						$(this).children(".layui-nav-child").offset({left:left});
					 
					}
					$(this).children(".layui-nav-child").offset({top:top});
		           
				
				   
			   }, function() {
				   
					$(this).children(".layui-nav-child").removeClass("layui-nav-hover");
					
					//判断当前是dd,还是 layui-nav-item
				
					$(this).children(".layui-nav-child").css({left: '0px'});
					
					$(this).children(".layui-nav-child").css({top: '0px'});
				})
			} else {
				$("#"+option.elem+" .layui-nav-item").off('mouseenter').unbind('mouseleave');
				$("#"+option.elem+" dd").off('mouseenter').unbind('mouseleave');
			}
		}
	
	    exports(MOD_NAME,new pearMenu());
})